package com.ihrm.common.interceptor;


import com.ihrm.common.entity.ResultCode;
import com.ihrm.common.exception.CommonException;
import com.ihrm.common.utils.JwtUtils;
import io.jsonwebtoken.Claims;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * 自定义拦截器
 *      继承HandlerInterceptorAdapter
 *
 *      preHandle:进入到控制器方法之前执行的内容
 *          boolean:
 *              true: 可以继续执行控制器方法
 *              false: 拦截
 *      posthandler: 执行控制器方法之后执行的内容
 *      afterCompletion: 响应结束之前执行的内容
 *
 * 1.简化获取token数据的代码编写
 *      统一的用户校验权限
 * 2.判断用户是否具有当前访问接口的权限
 *
 */
//@Component
public class JwtInterceptor extends HandlerInterceptorAdapter {
    
    /**
     * 简化获取token数据的代码编写（判断是否登录）
     *   1.通过request获取请求token信息
     *   2.从token中解析获取claims
     *   3.将claims绑定到request域中
     */
    
    @Autowired
    private JwtUtils jwtUtils;
    
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response,Object handler) throws Exception{
        /**
         * 通过request获取请求token信息
         */
        
        String authorization = request.getHeader("Authorization");
        System.out.println("已获取到:"+authorization);
        /**
         * 判断请求头信息是否为空，或者是否以Bearer开头
         */
        if(!StringUtils.isEmpty(authorization)&&authorization.startsWith("Bearer")){
            /**
             * 获取token数据
             */
            String token = authorization.replace("Bearer ", "");
            /**
             * 解析token获取claims
             */
            System.out.println("开始解析");
            Claims claims = jwtUtils.parseJwt(token);
            System.out.println("解析完成");
            if(claims!=null){
                /**
                 * 通过claims获取到当前用户的可访问API权限字符串
                 * api-user-delete,api-user-update
                 */
                String apis = (String) claims.get("apis");
                /**
                 * 通过handler
                 */
                HandlerMethod handlerMethod = (HandlerMethod) handler;
                /**
                 * 获取接口上的requestmapping注解
                 */
                RequestMapping annotation = handlerMethod.getMethodAnnotation(RequestMapping.class);
                /**
                 * 获取当前请求接口中的name属性
                 */
                String name = annotation.name();
                /**
                 * 判断当前用户是否具有响应的请求权限
                 */
                if(apis.contains(name)){
                    request.setAttribute("user_claims",claims);
                    return true;
                }else {
                    throw new CommonException(ResultCode.UNAUTHORISE);
                }
            }
        }
        throw new CommonException(ResultCode.UNAUTHENTICATED);
    }
}
